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DISTRIBUTED TEST CONTROL ARCHITECTURE 

BACKGROUND OF THE INVENTION 
1 * Field of the Invention 

The invention includes error detection/correction and 
5 fault detection/recovery. More particularly, the invention 

includes digital logic testing through a reduction in the 
number of global test control lines. 
2 * Background Information 

An integrated circuit or "chip" is a microelectronic 
10 semiconductor device having many interconnected transistors 

and other components. Chips may be fabricated on a small 
rectangle cut from a silicon wafer. The small size of these 
circuits allows high speed, low power dissipation, and 
reduced manufacturing cost compared with board-level 
15 integration. 

The first integrated circuits contained only a few 
transistors. Small Scale Integration (SSI) brought circuits 
containing transistors numbered in the tens. Later, Medium 
Scale Integration (MSI) contained hundreds of transistors and 
20 Large Scale Integration (LSI) contained thousands of 

transistors. At present Very Large Scale Integration (VLSI) 
circuit chips are composed of hundreds of thousands of logic 
elements or memory cells. Digital VLSI integrated oircuits 
may contain anything from one to millions of logic gates - 
25 inverters, gates, flip-flops, and multiplexors on a few 

square millimeters. 

Part of producing a scaleable VLSI chip includes testing 
and debugging the chip. Debugging is an attempt to determine 

1 
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the cause of any malfunction symptoms detected by testing. 
Circuitry may be built into an integrated circuit to assist 
in the test, maintenance, and support of an assembled 
circuit. Hardware features, known as design for test (DFT) 
5 features or resources, may be incorporated into a chip to aid 

in testing and debugging. 

Determining the cause of a malfunction or other problem 
may be achieved by using a testing machine to send a 
simulated signal from a debug pin residing on the perimeter 
10 of the chip to a logic element within the chip so as to 

trigger a response bit (0 or 1) from that logic element. On 
a clock signal, an instruction may cause a snapshot or "scan" 
to be taken of this triggered response bit by a DFT feature. 
On the next clock signal, and as part of that same 
15 instruction, the scan information bit may be shifted one bit 

"out" towards a serial output the chip to a second perimeter 
pin so that the scan bit may be compared to an expected 
response. If this triggered response or "scanout" varies 
from the expected response, then that particular logic 
20 element may be a cause of the noted problem. 

To adequately debug a chip, it may be necessary to view 
a sampled state of hundreds of chip-internal signals within a 
space of minutes. Conventionally, a first debugging 
technique may be used to isolate a probable bug location from 
25 a million transistors to a group of a few hundred 

transistors. Then, a second debugging technique may be used 
to rapidly find the exact transistor failure point from the 
grouped few hundred transistors. Chips may have redundant 
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transistors in them such that, once a transistor failure 
point is located, the transistor may be turned off as part of 
chip production while a redundant transistor may then 
similarly be turned on. 
5 To isolate a probable bug location from a million 

transistors to a group of a few hundred transistors, an 
integrated circuit chip may be designed to include internal 
read-only test points. These test points (or scanout 
"cells") generally are scattered throughout the integrated 
10 circuit chip. When chained together to form a distributed 

shift register, scanout cells produce parallel data that 
provides observability of selected nodes during functional 
testing during normal operation of the chip. 

U.S. patent 5,253,255 teaches a centralized control 
15 mechanism that employs two global test control lines for each 

design for test (DFT) feature. Here, sequentially activating 
the snapshot and the shift with signals requires two global 
speed critical signals that require close timing tolerances 
between the two signals. 
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RRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 illustrates platform 100 of the invention 
having chip 102 disposed on support structure 104; 

Figure 2 illustrates chip 200; 
5 Figure 3 illustrates chip 300 as a conventional 

modification of chip 200 of Figure 2; and 

Figure 4 illustrates chip 400 of the invention. 
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DETAILED DESCRIPTION OF THE INVENTION 
Figure 1 illustrates platform 100 of the invention 
having chip 102 disposed on support structure 104. Platform 
100 may be any structure having electronic components/ such 
5 as chip 102. For example, platform 100 may be a computer or 

computer system. Moreover, platform 100 may be a printed 
circuit board (PCB) . By way of background, a computer or 
other electronic system might be built from several PCBs, 
such as processor, memory, graphics controller, and disk 
10 controller. These boards might all plug into a motherboard 

or backplane or be connected by a ribbon cable. 

Chip 102 may be referred to as a processor or integrated 
circuit and may be thought of as a microelectronic 
semiconductor device having many interconnected transistors 
15 and other components. Platform 100 may also include memory 

controller 106, Peripheral Component Interconnect (PCI) 
bridge 108, and chip 110, each communicatively coupled 
through processor bus 112 . 

Memory controller 106 may be coupled to memory chips 
20 114. A controller may be thought of as that part of platform 

100 which allows platform 100 to use certain kinds of 
devices. Thus, memory controller 106 may be thought of as 
that part of platform 100 whioh allows platform 100 to use 
memory chips 114. Memory chips 114 may any device that can 
25 hold data in machine-readable format. 

PCI is a standard to connect external or peripheral 
devices to a personal computer. The PCI standard entitled 
PCI to PCI Bridge Architecture Specif icat ion {Rev. 1.1, PCI 
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Special Interest Group, Portland, Oregon, 1998) may be 
implemented as a mezzanine or a bridge, such as PCI bridge 
108. Here, PCI bridge 108 may include buffers to decouple 
chip 102 from relatively slow peripherals and to allow the 
5 peripherals to operate asynchronously. PCI bridge 108 may be 

coupled to external devices through controller 122 over PCI 
bus 124. These external devices may be input devices such as 
keyboard 116, mouse 118 , and modem 120. 

Chip 110 may be an integrated circuit that is similar to 

10 chip 102. Chip 102 may include bus interface unit (BIU) 126 

and test controller 128. BIU 126 may operate as an 
input/output port to communicated signals between processor 
bus 112 and chip 102. Test controller 128 may be any device 
that asserts test instructions to design for test (DFT) 

15 features, where DFT may be design and hardware features 

incorporated into chip 102 to aid in manufacturing and 
debugging . 

Also coupled to platform 100 may be tester 130. Tester 
130 may be a VLSI tester that communicates test instructions 

20 to test controller 128 over bus 132. Bus 132 may be thought 

of as a test and maintenance bus used as part of the 
interface design to access chip 102. Institute of Electrical 
and Electronics Engineers (IEEE) standard 1149.1, entitled 
Test Access Port and Boundary -Scan Architecture, is an 

25 internationally recognized design standard specifying product 

design and test protocols. Particularly, IEEE 1149.1 may 
specify the interface design to access a chip for testing 
purposes. In one embodiment, bus 132 meets the five-pin 
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requirement of IEEE standard 1149.1. Moreover, under IEEE 
1149.1, a test access port (TAP) may be an example of test 
controller 128. 

Figure 2 illustrates chip 200. Chip 200 may include 
5 logic units 202, 204, 206, 208, 210, and 212, each of which 

may deal with basic operations of a computer system. For 
example, logic unit 202 may be a floating point unit (FPU), 
logic unit 204 may be an arithmetic logic unit (ALU) , and 
logic 212 may be a memory logic. Each logic unit may be 

10 coupled to bus interface unit 214 through logic unit 

controllers 216, 218, 220, 222, 224, and 226 as shown. These 
controllers local to the logic units of chip 200 may be 
positioned very close to their respective logic unit. 
Moreover, bus interface unit (BIU) 214 may be similar to BIU 

15 126 of Figure 1. 

Clock generator 227 may be a core clock that is 
connected between each logic unit controller and BIU 214. 
Clock or clock generator 227 may produce a isi^nal which may 
be distributed over clock lines within chip 200 in a tree 

20 like structure to the logic units 202, 204, 206, 208, 2113, 

and 212. Each clock signal of a given clock pulse may need 
to reach its destination within a timing window for events 
within chip 200 to be synchronized. Timing skew may be 
thought of the variation between the arrival moment of a 

25 first signal as compared to the arrival moment of one or more 

other signals at the same or different logic unit. 
Controllers may be placed within chip 200 to control this 
timing skew. These deskew (DS) controllers may include a 
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whole host of logic elements that aid in receiving, 
processing, and retransmitting signals such as clock signals 
and instructions to the logic units so as to synchronize the 
arrival of all instructions to their associated logic unit, 
5 In other words, DS controllers may aid in minimizing any 

timing skew between the signals. Logic unit controllers 216, 
218, 220, 222, 224, and 226 may be DS controllers. As will 
be discussed below, the invention takes advantage of logic 
unit controllers 216-226 to receive, process, and retransmit 
10 testing signals to reduce the number of global test control 

lines . 

Part of producing a working chip includes testing and 
debugging that chip. Debugging is an attempt to determine 
the cause of any malfunction symptoms detected by testing. 
15 Circuitry may be built into an integrated circuit to assist 

in the test, maintenance, and support of an assembled 
circuit. Hardware features, known as design for test (DFT) 
features, may be incorporated into a chip to aid in testing 
and debugging. 

20 Each logic unit within chip 200 may be coupled to cells 

chained together to form a register. For example, logic 208 
may be coupled to register 228 having cells 230, 232, 234, 
and 236. Logic 212 may be coupled to register 238 having 
cells 240, 242, 244, 246, 248, and 250. Cells 230-236 and 

25 240-250 may be examples of DFT features. 

Chip 200 may additionally include test controller 252 
and tester 254. Test controller 252 may be viewed as an 
integrated test controller when residing within chip 200. 
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Included within test controller 252 may be an instruction 
register (IR) and a test access port finite state machine 
(TAP FSM) as described in IEEE 1149.1. Test controller 252 
and tester 254 may be similar to test controller 128 and 
5 tester 130 of Figure 1, respectively. 

Figure 3 illustrates chip 300. Chip 300 may be a 
conventional modification of chip 200 of Figure 2. 
Conventionally, one global test control line is required to 
run between test controller 252 and a DFT feature for each 

10 type of instruction signal. For example, to transmit a load 

signal and a test signal from ITC 252 and register 238 of 
Figure 3, chip 300 may employ global test control lines 302 
and 304, respectively. In a similar way, lines 306 and 308 
may run between ITC 252 and register 228. In other words, 

15 for a scanout process, each DFT feature conventionally may 

employ two global test control lines. For a different type 
of testing process, each design for test Feature 
conventionally may employ three, four, five or more global 
test control lines. 

20 Chips conventionally include fifty to one hundred global 

test control lines to transmit information to anywhere from 
5,200 DFT features to 49,000 DFT features. These global test 
control lines may limit chip designers in the placement and 
arrangement of the control lines and logical units on chip 

25 300 by taking up valuable space on chip 300. More 

restrictively, the timing of the signals distributed by each 
of these global test control lines is critical. As noted 
below, the invention may reduce the number of global test 
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control lines to nineteen (for example, one bus having 
nineteen lines) to transmit that same information to the 
design for test Features of a chip. 

Figure 4 illustrates chip 400 of the invention. As can 
5 be readily seen, chip 400 may be a modification of chip 200 

of Figure 2. Included with chip 400 may be internal test 
bus 402 disposed between ITC 252 and logic unit controller 
226 and internal test bus 404 disposed between ITC 252 and DS 
controller 222. Chip 400 may also include additional 

10 internal test buses (not shown) disposed between ITC 252 and 

each logic unit controller within chip 400. 

Each internal test bus (ITB) of chip 400 may be adapted 
to pass test instruction signals as a test instruction packet 
from ITC 252 to a logic unit controller. Although the bits 

15 of these signals may travel over different lines, these 

different lines may be within a single internal test bus 
having a single routing path between ITC 252 and a logic unit 
controller. Moreover, these test instruction signals may 
travel according to a clock that is internal to tester 254 

20 rather than the core clock that is internal to chip 400, here 

clock 227. For these and other reasons, timing is not 
critical with respect to signals routed within an internal 
test bus of the invention. 

To transmit a test information packet in parallel, each 

25 internal test bus of chip 400 may include n number of lines 

such that 

n = a + log 2 i (500) 

where 
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n = number of lines, 

a = number of ancillary transmission bits, and 
log 2 i = number of instruction bits. 

Ancillary transmission bits may be those supporting bits 
5 that may needed to accompany the instruction bits. For a 

given distributed test control architecture compliant with 
IEEE 1149.1, the number of ancillary transmission bits may be 
a constant. The number of instruction bits <log 2 i) may be 
thought of as a bit stream of zeros and ones. Moreover, the 

1*0 number of instruction bits (log 2 i) may represent the number of 

unique testing tasks that are desired to be performed within 
the collective of logic unit controllers (e.g., 222 and 226) 
of chip 400. For example, where the number of instruction 
bits equals eight (8 = log 2 256) , the test instruction packet 

15 may include up to two hundred and fifty six (256) unique 

testing task signals. The instruction bits may be disposed 
within an IEEE 1149.1 instruction register content. 

In one embodiment, the information transmitted over 
internal test bus 402 may include a shift signal and a load 

2-0 signal. In another embodiment, the information transmitted 

over internal test bus 402 may include a one-bit clock signal 
and the following five components representing eighteen bits: 

(i) instruction register contents (8 bits); 

(ii) partially encoded, relevant states of a test access 
25 port finite state machine (TAP FSM) (4 bits); 

(iii) security-bit (1 bit) ; 

(iv) test data input (TDI) (1 bit); and 

(v) counter value from a Wave Shaper (4 bits) . 
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Component (i) may be thought of the number of 
instruction bits (log 2 i) and components (ii), (iii) , (iv), and 
(v) may be thought of as ancillary transmission bits (a) . 
Accordingly, from equation 500 above, 

19 ='(1+4+1+1+4) + log 2 25€ (500). 
These nineteen bits of information may travel as a test 
information packet. Where the test instruction packet is 
encoded, the logic unit controller may include components 
that decode the test instruction packet. 

Not all the states of the test access port finite state 
machine (TAP FSM) need be transmitted over a test bus (402, 
404) of chip 400. This may be true where the state in 
question is not relevant to control DFT logic internal to 
chip 400. In one embodiment, the relevant states of TAP FSM 
under IEEE 1149.1 include the following six states: test- 
logic-reset (tlr), run-test/idle (rti) , capture-down register 
(capDR) , shift-DR (shiftDR) , update-DR (updtDR) , and dead (the 
remaining eleven states) . Accordingly, in one embodiment of 
the invention, a subset of all the states of a test access 
port finite state machine are encoded into three bits. In 
another embodiment, individual bits may be allocated for 
test-logic-reset (tlr) and run-test/idle (rti) and the 
residual (remainder) states (capDR, shiftDR, updtDR, and 
dead) are allocated among two bits. 

On receiving a test instruction packet, a logic unit 
controller may locally generate whatever testing signals are 
needed for the desired testing operation. For example, on 
receiving a test instruction packet having a shift signal and 
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a load signal, logic unit controller 226 may process the test 
instruction packet to locally generate a shift signal and a 
load signal. Logic unit controller 226 may then pass these 
two signals to register 238 over the relatively short 
5 distance of distributed test line 406 and distributed test 

line 408, respectively. 

Under the conventional method of Figure 3, a shift 
signal and a load signal each travel separately over its own 
global test control line between the ITC 252 and register 

10 238. The independent travel of these and other test signals 

over a relatively great distance requires tight or critical 
control over the timing of these signals. In .contrast, the 
invention transmits these signals as an instruction bundle or 
packet between the ITC 252 and logic unit controller 226 so 

15 as to eliminate the number of global test control lines and 

the requirement for critical timing. 

The invention may be employed as a method to control at 
least one DFT feature, such as register 238 of Figure 4. A 
test information packet may first be generated in a test 

20 controller of an integrated circuit. The test information 

packet may then be transmitted to at least one logic unit 
controller over a test bus coupled between the test 
controller and the at least one logic unit -controller. The 
test information packet may then be processed within the at 

25 least one logic unit controller to generate at least one test 

control signal. The at least one test control signal may be 
transmitted to the at least one DFT feature coupled to the 
logic unit controller. A logic unit -coupled to the at least 
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one DFT feature may be interacted with based on the at least 
one test control signal. 

The distributed test control scheme of the invention 
works towards reducing the number of global test control 
lines, relax routing constraints on the test control lines, 
and add greater flexibility in the physical placement of the 
test controller and test control logic. This may translate 
to lower silicon area and reduced design effort (cost, 
efficiency, quality, reliability, and timeliness) . Moreover, 
the distributed test control scheme of the invention is 
scalable and flexible; that is to say, the distributed test 
control scheme may include the ability to add support for new 
test features late in the design cycle and implement fixes 
with relatively small impact on schedule. 

The exemplary embodiments described herein are provided 
merely to illustrate the principles of the invention and 
should not be construed as limiting the scope of the subject 
matter of the terms of the claimed invention. The 
specification and drawings are, accordingly, to be regarded 
in an illustrative rather than a restrictive sense. 
Moreover, the principles of the invention may be applied to 
achieve the advantages described herein and to achieve other 
advantages or to satisfy other objectives, as well. 
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CLAIMS 

What is claimed is: 

1 A.. An integrated circuit comprising: 

2 ^ a test controller; 

3 at least one logic unit controller; 

4 a test bus coupled between the test controller and the 

5 at least one logic unit controller; 

6 at least one design for test feature coupled to the at 

7 least one logic unit controller; and 

8 a logic unit coupled to the at least one design for test 

9 feature* 

1 2 . The integrated circuit of claim 1 wherein the test 

2 controller is an integrated test controller 

1 3. The integrated circuit of claim 1 wherein the logic 

2 unit controller is a deskew controller 

1 4. The integrated circuit of claim 1 wherein the test 

2 bus is an internal test bus. 

1 5 . The integrated circuit of claim 4 wherein the 

2 internal test bus includes n number of lines such that 

3 n = a + log 2 i 

4 where n = number of lines, a = number of ancillary 

5 transmission bits, and log 2 i = number of instruction bits. 

1 6. The integrated circuit of claim 5 wherein the number 

2 of instruction bits are represented within the content of an 
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3 instruction register that is compliant with IEEE 1149.1. 

1 7. The integrated circuit of claim 5 wherein the 

2 ancillary transmission bits include at least one of a clock 

3 signal, at least one state of a test access port finite state 

4 machine, a security bit, a test data input, and a counter 

5 value . 

1 8. The integrated circuit of claim 7 wherein the at 

2 least one state of a test access port finite state machine 

3 are encoded into three bits. 

1 9. The integrated circuit of claim 7 wherein the at 

2 least one state of a test access port finite state machine is 

3 allocated into a one-bit test- logic -reset state, a one bit 

4 run-test/idle state, and a two-bit residual state. 

1 ^0 . A platform comprising: 

2 an external device; 

3 a support structure; 

4 a controller disposed on the support structure and 

5 coupled to the input device; 

6 at least one memory chip disposed on the support 

7 structure and coupled to the controller through a processor 

8 bus ; and 

9 an integrated circuit having a test controller, at least 

10 one logic unit controller, a test bus coupled between the 

11 test controller and the at least one logic unit controller, 

12 at least one design for test feature coupled to the logic 

13 unit controller, and a logic unit coupled to the at least one 
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14 design for test feature. 

1 11. The platform of claim 10 wherein the external device 

2 is at least one of a keyboard, a mouse, and a modem. 

1 12 . The platform of claim 10 wherein at least one of the 

2 following is true: the test controller is an integrated test 

3 controller; the logic unit controller is a deskew controller; 

4 and the test bus is an internal test bus. 

1 13 . The platform of claim 12 wherein the internal test 

2 bus includes n number of lines such that 

3 n = a + log 2 i 

4 where n = number of lines, a = number of ancillary 

5 transmission bits, and log 2 i = number of instruction bits. 

1 14. The platform of claim 13 wherein the number of 

2 instruction bits are represented within the -content of an 

3 instruction register that is compliant with IEEE 1149.1. 

1 15. The platform of claim 13 wherein the ancillary 

2 transmission bits include at least one of a clock signal, at 

3 least one state of a test access port finite state machine, a 

4 security bit, a test data input, and a counter value. 

1 16. The platform of claim 15 wherein the at least one 

2 state of a test access port finite state machine are encoded 

3 into three bits. 

1 17 . The platform of claim 15 wherein the at least one 

2 state of a test access port finite state machine is allocated 
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3 into a one bit test-logic-reset state, a one bit run- 

4 test /idle state, and a two bit residual state. 

1 A method comprising: 

2 generating a test information packet in a test 

3 controller of an integrated circuit; 

4 transmitting the test information packet to at least one 

5 logic unit controller over a test bus coupled between the 

6 test controller and the at least one logic unit controller; 

7 processing the test information packet within the at 

8 least one logic unit controller to generate at least one test 

9 control signal; and 

10 transmitting the at least one test control signal to the 

11 at least one design for test feature coupled to the logic 

12 unit controller. 

1 19. The method of claim 18 further comprising: 

2 interacting with a logic "unit coupled to the at Least 

3 one design for test feature based on the at least one test 

4 control signal. 

1 20. The method of claim 19 wherein transmitting the test 

2 information packet to at least one logic unit controller over 

3 the test bus includes transmitting the test information 

4 packet over n number of lines such that 

5 n = a + log 2 i 

6 where n = number of lines, a = number of ancillary 

7 transmission bits, and log 2 i = number of instruction bits. 
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ABSTRACT 

The invention includes an integrated circuit. The 
integrated circuit may include a test controller, at Least 
one logic unit controller, and a test bus coupled between the 
test controller and the logic "unit controller. A design for 
test feature may be coupled to the one logic unit controller. 
Moreover, a logic unit may be coupled to the at least one 
design for test feature. 
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